//
//  Problem1290.swift
//  TestProject
//
//  Created by 毕武侠 on 2021/5/9.
//  Copyright © 2021 zhulong. All rights reserved.
//

import UIKit

/*
 1290. 二进制链表转整数
 给你一个单链表的引用结点 head。链表中每个结点的值不是 0 就是 1。已知此链表是一个整数数字的二进制表示形式。
 请你返回该链表所表示数字的 十进制值 。

 示例 1：
     输入：head = [1,0,1]
     输出：5
     解释：二进制数 (101) 转化为十进制数 (5)
 示例 2：
     输入：head = [0]
     输出：0
 示例 3：
     输入：head = [1]
     输出：1
 示例 4：
     输入：head = [1,0,0,1,0,0,1,1,1,0,0,0,0,0,0]
     输出：18880
 示例 5：
     输入：head = [0,0]
     输出：0

 提示：
     链表不为空。
     链表的结点总数不超过 30。
     每个结点的值不是 0 就是 1。
 */
@objcMembers class Problem1290: NSObject {
    func solution() {
        let root = ListNode(1)
        root.next = ListNode(0)
        root.next?.next = ListNode(1)
        print(getDecimalValue(root))
    }
    
    func getDecimalValue(_ head: ListNode?) -> Int {
        var result = 0
        var root = head
        while root != nil {
            result = result * 2 + (root?.val ?? 0)
            root = root?.next
        }
        return result
    }
}
